找传奇、传世资源到传世资源站!

android 实现js交互(互相调用) 示例源码下载

8.5玩家评分(1人评分)
下载后可评
介绍 评论 失效链接反馈

android 实现js交互(互相调用) 示例源码下载 Android平台开发-第1张package jwzhangjie.com.webviewandjs;import android.content.Context;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;import android.webkit.JavascriptInterface;import android.webkit.WebView;import android.webkit.WebViewClient;import android.widget.Toast;public class MainActivity extends AppCompatActivity { private WebView webView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); webView = (WebView)findViewById(R.id.webView); initWebView(); } private void initWebView(){ //设置编码 webView.getSettings().setDefaultTextEncodingName("utf-8"); //支持js webView.getSettings().setJavaScriptEnabled(true); //设置监听事件 webView.setWebViewClient(new JieWewViewClient()); //设置本地调用对象及其接口 webView.addJavascriptInterface(new JavaScriptObject(getApplicationContext()), "toAndroid"); //载入js webView.loadUrl("file:///android_asset/index.html"); } public void javaCallJsNoParams(View view){ webView.loadUrl("javascript:javaCallJsNoParamsMethod()"); } public void javaCallJsHasParams(View view){ webView.loadUrl("javascript:javaCallJsHasParamsMethod('" 123 "')"); } public class JavaScriptObject { Context mContxt; public JavaScriptObject(Context mContxt) { this.mContxt = mContxt; } @JavascriptInterface //sdk17版本以上加上注解 public void jsCallJavaNoParams() { Toast.makeText(mContxt, "Js调用Java方法(无参)", Toast.LENGTH_LONG).show(); } @JavascriptInterface //sdk17版本以上加上注解 public void jsCallJavaHasParams(String params) { Toast.makeText(mContxt, "Js调用Java方法(有参):" params, Toast.LENGTH_SHORT).show(); } } class JieWewViewClient extends WebViewClient{ /** * 如果紧跟着 * webView.loadUrl("file:///android_asset/index.html"); * 调用Js中的方法是不起作用的,必须页面加载完成才可以 */ @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); webView.loadUrl("javascript:javaCallJsHasParamsMethod('" 123 "')"); } }}

评论

发表评论必须先登陆, 您可以 登陆 或者 注册新账号 !


在线咨询: 问题反馈
客服QQ:174666394

有问题请留言,看到后及时答复